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Foreword 



This Technical Specification has been produced by the 3GPP. 

The present document defines an error concealment procedure, also termed frame substitution and muting procedure, of 
the wideband telephony speech service employing the Adaptive Multi-Rate - Wideband (AMR-WB) speech coder 
within the 3GPP system. 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of this TS, it will be re-released by the TSG with an identifying 
change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 Indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the specification; 
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Scope 



This specification defines an error concealment procedure, also termed frame substitution and muting procedure, which 
shall be used by the AMR-WB speech codec receiving end when one or more erroneous/lost speech or lost Silence 
Descriptor (SID) frames are received. 

The requirements of this document are mandatory for implementation in all networks and User Equipment (UE)s 
capable of supporting the AMR-WB speech codec. It is not mandatory to follow the bit exact implementation outlined 
in this document and the corresponding C source code. 



Normative references 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[1] 3GPP TS 26.202"AMR Wideband Speech Codec; Interface to RAN". 

[2] 3GPP TS 26.190"AMR Wideband Speech Codec; Transcoding functions". 

[3] 3GPP TS 26.193"AMR Wideband Speech Codec; Source Controlled Rate operation". 

[4] 3GPP TS 26.201"AMR Wideband Speech Codec; Frame structure". 



3 Definitions and abbreviations 

3.1 Definitions 

For the purposes of this document, the following definition applies: 

N-point median operation: Consists of sorting the N elements belonging to the set for which the median operation is 
to be performed in an ascending order according to their values, and selecting the (int (N/2) + 1) -th largest value of the 
sorted set as the median value. 

Further definitions of terms used in this document can be found in the references. 
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3.2 Abbreviations 

For the purposes of this document, the following abbreviations apply: 

AMR-WB Adaptive Multi Rate - WideBand 

AN Access Network 

BFI Bad Frame Indication from AN 

BSI_netw Bad Sub-block Indication obtained from AN interface CRC checks 

prevBFI Bad Frame Indication of previous frame 

RX Receive 

SCR Source Controlled Rate (operation) 

SID Silence Descriptor frame (Background noise) 

CRC Cyclic Redundancy Check 

ECU Error Concealment Unit 

BFH Bad Frame Handling 

medianN N-point median operation 



General 



The purpose of the error concealment procedure is to conceal the effect of erroneous/lost AMR-WB speech frames. The 
purpose of muting the output in the case of several erroneous/lost frames is to indicate the breakdown of the channel to 
the user and to avoid generating possible annoying sounds as a result from the error concealment procedure. 

The network shall indicate erroneous/lost speech or lost SID frames by setting the RX_TYPE values [3] to 
SPEECH_B AD, SID_B AD or SPEECH_LOST. If these flags are set, the speech decoder shall perform parameter 
substitution to conceal errors. 

The example solution provided in paragraph 6 apply only to bad frame handling on a complete speech frame basis. Sub- 
frame based error concealment may be derived using similar methods. 



5 Requirements 

5.1 Error detection 

If the most sensitive bits of the AMR-WB speech data (class A in [4]) are received in error, the network shall indicate 
RX_TYPE = SPEECH_BAD in which case the BFI flag is set. When the frame is not received, the network shall 
indicate RX_TYPE = RX_SPEECH_LOST in which case the BFI flag is set as well. If a SID frame is received in error, 
the network shall indicate RX_TYPE = SID_BAD.. 

5.2 Erroneous or lost speech frames 

Normal decoding of erroneous/lost speech frames would result in very unpleasant noise effects. In order to improve the 
subjective quality, erroneous/lost speech frames shall be substituted with either a repetition or an extrapolation of the 
previous good speech frame(s). This substitution is done so that it gradually will decrease the output level, resulting in 
silence at the output. Subclause 6 provides example solution. 

5.3 First lost SID frame 

A lost SID frame shall be substituted by using the SID information from earlier received valid SID frames and the 
procedure for valid SID frames be applied as described in [3]. 
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5.4 Subsequent lost SID frames 



For many subsequent lost SID frames, a muting technique shall be applied to the comfort noise that will gradually 
decrease the output level. For subsequent lost SID frames, the muting of the output shall be maintained. Subclause 6 
provides example solutions. 



Example ECU/BFH Solution 



6.1 State Machine 

This example solution for substitution and muting is based on a state machine with seven states (Figure 1). 

The system starts in state 0. Each time a bad frame is detected, the state counter is incremented by one and is saturated 
when it reaches 6. Each time a good speech frame is detected, the state counter is right-shifted by one. The state 
indicates the quality of the channel: the larger the value of the state counter, the worse the channel quality is. The 
control flow of the state machine can be described by the following C code (BFI = bad frame indicator. State = state 
variable): 

if(BFI != ) 

State = State + 1 ; 

if(State > 6) 
State = 6; 
else 

State = State » 1 ; 

In addition to this state machine, the Bad Frame Flag from the previous frame is checked (prevBFI). The processing 
depends on the value of the State- variable. In states and 6, the processing depends on the BFI flag. 
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The procedure can be described as follows: 



f 



STATE = 

BFI = 
PrevBFI = or 1 



i 



/\ 



tiTATE = i — 

(BFI, prevBFI) = 

(1,0) or (0,1) or 
(0,0) 



■> 



I 



<■ 



STATE = 2 

(BFI, prevBFI) = 
(1,1) or (1,0) or 
(0,1) 



I 



STATE = 3 

(BFI, prevBFI) = 

(1,1) or (1,0) or 
(0,1) 



I 



^tAte = 4 

BFI=1 
prevBFI = or 1 



I 



STATE = 5 

BFI=1 
prevBFI = 1 



1 



STATE = 6 

BFI=1 
prevBFI = 1 



J 



-► Bad frame (BFI=1) 
-^ Good frame (BFI=0) 



Figure 1 : State machine for controlling the bad frame substitution 
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6.2 Substitution and muting of erroneous/lost speech frames 

6.2.1 BFI = 0, prevBFI = 0, State = or 1 

No error is detected in the received or in the previous received speech frame. The received speech parameters are used 
normally in the speech synthesis. The current frame of speech parameters is saved. 

6.2.2 BFI = 0, prevBFI = 1 , State = to3 

No error is detected in the received speech frame but the previous received speech frame was bad. The LTP gain is used 
normally in the speech synthesis and fixed codebook gain are limited below the values used for the last received good 
subframe: 



g (n) = \ ^ (1) 

|1.25*g (n-1) ,otherwise 

where 

S deceived ~ Current decoded fixed codebook-gain 

^ '^ (n — 1) = fixed codebook gain used for the last good subframe (BFI = 0) 

g (n) = fixed codebook gain to be used for the current frame. 

The rest of the received speech parameters are used normally in the speech synthesis. The current frame of speech 
parameters is saved. 

6.2.3 BFI = 1 , prevBFI = or 1 , State = 1 ...6 

An error is detected in the received speech frame and the substitution and muting procedure is started. 

6.2.3.1 LTP gain & fixed codebook gain concealment 

when RX_FRAMETYPE = SPEECH_BAD 

The LTP gain g ^ and fixed codebook gain g ^ are replaced by attenuated values from the previous subframes: 
g'' =P''(state)*median5(g''(n-l),...,g''(n-5)) (2) 

\P'(state)* median5(g' (n-l),...,g' in-5)) ,VAD_HIST<2 

g"" = i 

[median5(g' (n-l),...,g' (n-5)) ,VAD_HIST>2 



(3) 



where: 



* = current decoded LTP gain, 

g"^ = current decoded fixed codebook gain, 

g '' (n — V),..., g'' (n — 5) = LTP gains used for the last 5 subframes, 

g"^ (jl — 1),.--5 g"^ in — 5)= fixed codebook gains used for the last 5 subframes, 
median5() = 5-point median operation, 
P'' {state) = attenuation factor (P''(l) = 0.98, P'' (2) = 0.96, P'' (3) = 0.75, P'' (4) = 0.23, P'' (5) = 0.05, 

P''(6) = 0.01), 
P' (state) = attenuation factor (P' (1) = 0.98, P' (2) = 0.98, P' (3) = 0.98, P" (4) = 0.98, P' (5) = 0.98, 
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P' (6) = 0.70), 
state = state number {0..6}, 
VAD_HIST is number of consecutive VAD=0 decisions. 



The higher the state value is, the more the gains are attenuated. Also the memory of the predictive fixed codebook gain 
is updated by using the average value of the past four values in the memory: 



ener 



(o)=i 



^ener{n-i) 



(4) 



6.2.3.2 LTP gain & fixed codebook gain concealment 

when RX_FRAMETYPE = SPEECH_LOST 

The LTP gain g ^ and fixed codebook gain g ^ are replaced by attenuated values from the previous subframes: 



g'' =P'' {state) * median5(g '' (n - 1),.. ., ^ ^ (n - 5)) 

\ P" (state) * medianSig'^ (n -1),..., g'' (n - 5)) 
s'' = \ 

[medianSig '^ (n - 1),..., g"^ (n- 5)) 



,VAD_HIST<2 
,VAD HIST > 2 



(5) 



(6) 



where: 



* = current decoded LTP gain, 

g'' = current decoded fixed codebook gain, 

g '' (n — 1),..., g'' (n — 5) = LTP gains used for the last 5 subframes, 

^^(n — 1),.",^' (^ ~5)= fixed codebook gains used for the last 5 subframes, 

median5() = 5-point median operation, 

P'' (state) = attenuation factor (P''(l) = 0.95, P'' (2) = 0.90, P''(3 ) = 0.75, P'' (4) = 0.23, P^ (5) = 0.05, 

P'' (6) = 0.01), 

P' (state) = attenuation factor (P' (1) = 0.50, P' (2) = 0.25, P' (3) = 0.25, P' (4) = 0.25, P" (5) = 0. 15, 

P' (6) = 0.01), 
state = state number {0..6}, 
VAD_HIST is number of consecutive VAD=0 decisions. 



The higher the state value is, the more the gains are attenuated. Also the memory of the predictive fixed codebook gain 
is updated by using the average value of the past four values in the memory: 



ener 



(o)=i 



2_^ener{n-i) 



(7) 



6.2.3.3 ISF concealment 

The past ISFs are shifted towards their partly adaptive mean: 

ISF^ (i) = a * past _ ISF^ (i) + (l-a)* ISF^^^„ (i) 
where 



i=0..16(8) 
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a =0.9, 

ISF (l) is ISF-vector for a current frame, 

past _ ISF (i) is ISF-vector from the previous frame, 

ISF^^^^(i) vector is combination of adaptive mean and constant mean ISF- vectors in the following manner: 

ISF^e.n (0 = J3 * ISF^ons,_mean (0 + C^ ' Z^) * ISF^,ar.i.e _.,ean (0 ^ '=0..16 (9) 

where 

P =0.75, 



1 ^ 

ISF^dap,ive_mean(i) = 'YjP^^^ -^^^i^") ^"^^ '^ "P'^^^^'^ whenever BFI =0. 
^^■^comt mean (') ^^ ^ vcctor Containing long time average of ISF-vectors. 



6.2.3.4 LTP-lag concealment 

The histories of five last good LTP-lags and LTP-gains are used for finding the best method to update. 

6.2.3.4.1 LTP-lag concealment when RX_FRAMETYPE = SPEECH_BAD 

The usability of the received LTP lag ( Q, ) is defined as follows: (Predicts if the received lag is most probably very 
close to one that was sent and therefore its usage should not introduce any bad artifacts) 

, r,„ < 10 and T_ - 5 < r„,,,,,, < T^„ + 5 
,g''(n-l)>0.5andgP(n-2)>0.5andT(n-l)-10<r_,,,, <T(n-l) + 10 



^lae — 



'L < 0.4 and gnn-\) = ^^ and T^„ < r_,,,, < T, 



mill min received ~ max (\(\\ 



,r„y < 70 and T^„ < r„^^.,^^ < T^^ 
T <T < T 

' mean received max 

^0 , otherwise 

where: 

T{n — X) is LTP lag from the previous good frame, 

^ dif ~ \^ received ~ ^ \^ ~ ^)\ ^ 

?;.„ = min(7;^„^^^ J , 
7;ax = max(r,„^^^J , 

Treceived '^^ rCCCivcd lag, 

^™n=min(^,V)' 

^ '' is LTP gain of the current frame, 

^'' (-1) is LTP gain of the previous good frame, 

g '' (-2) is LTP gain of the frame before previous good frame, 

Tmean = avemge{T,^ffJ 

LPT lag value for the current frame is defined as follows: 
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T = 



received 



^E(^max +7^™ax-l + T^.-l) + RND(T^^ -J^.,) 



13 






(11) 



where: 



max(r, ,. ) 



max— 1 



is second largest value in 7], 



tojfcr ■ 



7'max-2is second largest value in r^„^^^ , 
RND(x) is random value generated to range 



X X 



6.2.3.4.2 LTP-lag concealment when RX_FRAMETYPE = SPEECH_LOST 

The usability of the LTP lag from last good frame ( Q, ,_j ) is defined as ft)llows: (Predicts if the received lag is most 
probably very close to one that was sent and therefore its usage should not introduce any bad artifacts) 



Qu 



,gL>0.5andT,, <10 
,gP(n-l)>0.5andgP(n-2)>0.5 
, otherwise 



where: 



r™n=min(^,V)' 



g (n-1) is LTP gain of the previous good frame, 

g '' (n-2) is LTP gain of the frame before previous good frame 



(12) 



LPT lag value for the current frame is defined as follows: 
'r(n-l) 



T = 



where: 



T(n — V) is LTP lag from the previous good frame, 
T^ax = max(r,„^^J , 

T'max-i is second largest value in T^^^^^ , 

T'max-ais second largest value in T^^^^^ , 



RND(x) is random value generated to range 



X X 

r^2 



'Qlag_.-l=l 
,Qla^.l=0 



(13) 



6.2.4 Innovation sequence 

When RX_FRAMETYPE = SPEECH_BAD, the received fixed codebook innovation pulses from the erroneous frame 
are used as they are received. 
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When RX_FRAMETYPE = SPEECH_LOST, the received fixed codebook innovation pulses from the erroneous frame 
are not used and the fixed codebook innovation vector is filled with random signal (values limited to 
range [-1, +1]). 

6.2.5 High-band gain (for 23.85 kbit/s mode) 

When RX_FRAMETYPE = SPEECH_BAD or RX_FRAMETYPE = SPEECH_LOST the received high-band energy 
parameter of the frame is not used and the estimation for the high-band gain is used instead. This means that in case of 
bad/lost speech frames, the high-band reconstruction operates in the same way for all the modes. 

6.3 Substitution and muting of lost SID frames 

In the speech decoder a single frame classified as SID_BAD shall be substituted by the last valid SID frame information 
and the procedure for valid SID frames be applied. If the time between SID information updates (updates are specified 
by SID_UPDATE arrivals and occasionally by SID_FIRST arrivals) is greater than one second this shall lead to 
attenuation. 
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